package com.ruoyi.mall.mapper;

import com.ruoyi.mall.domain.DeleteObject;
import com.ruoyi.mall.domain.GoodsClass;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Select;

import java.util.List;

/**
 * 商品分类Mapper接口
 *
 * @author ruoyi
 * @date 2025-08-13
 */
public interface GoodsClassMapper {
    /**
     * 查询商品分类
     *
     * @param id 商品分类主键
     * @return 商品分类
     */
    public GoodsClass selectGoodsClassById(Long id);

    /**
     * 查询商品分类列表
     *
     * @param goodsClass 商品分类
     * @return 商品分类集合
     */
    public List<GoodsClass> selectGoodsClassList(GoodsClass goodsClass);

    /**
     * 新增商品分类
     *
     * @param goodsClass 商品分类
     * @return 结果
     */
    public int insertGoodsClass(GoodsClass goodsClass);

    /**
     * 修改商品分类
     *
     * @param goodsClass 商品分类
     * @return 结果
     */
    public int updateGoodsClass(GoodsClass goodsClass);

    /**
     * 删除商品分类
     *
     * @param id 商品分类主键
     * @return 结果
     */
    public int deleteGoodsClassById(Long id);

    /**
     * 批量删除商品分类
     *
     * @param ids 需要删除的数据主键集合
     * @return 结果
     */
    public int deleteGoodsClassByIds(Long[] ids);

    @Select("SELECT `name`,delcount.counts FROM t_goods_class,(SELECT COUNT(*) counts FROM t_goods WHERE gatgory_id=#{id} AND is_delete=0) AS delcount WHERE id=#{id}")
    DeleteObject deleteObject(@Param("id") long id);

    @Select("select name from t_goods_class where id=#{id}")
    String selName(@Param("id") long id);

    @Select("SELECT count(*) from t_goods_class where `name`=#{name} and is_delete=0")
    int selCount(@Param("name") String name);
}
